home *** CD-ROM | disk | FTP | other *** search
/ Computer Select (Limited Edition) / Computer Select.iso / dobbs / v17n02 / uxdriver.exe / WDREG.H < prev   
Encoding:
C/C++ Source or Header  |  1991-11-19  |  3.8 KB  |  90 lines

  1. /* wdreg.h
  2.  * Copyright (c) 1991 The Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * This code is derived from software contributed to Berkeley by
  6.  * William Jolitz.
  7.  *
  8.  * Redistribution and use in source and binary forms, with or without
  9.  * modification, are permitted provided that the following conditions
  10.  * are met:
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer.
  13.  * 2. Redistributions in binary form must reproduce the above copyright
  14.  *    notice, this list of conditions and the following disclaimer in the
  15.  *    documentation and/or other materials provided with the distribution.
  16.  * 3. All advertising materials mentioning features or use of this software
  17.  *    must display the following acknowledgement:
  18.  *    This product includes software developed by the University of
  19.  *    California, Berkeley and its contributors.
  20.  * 4. Neither the name of the University nor the names of its contributors
  21.  *    may be used to endorse or promote products derived from this software
  22.  *    without specific prior written permission.
  23.  *
  24.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  25.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  26.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
  27. PURPOSE
  28.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  29.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  30.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  31.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  32.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 
  33. STRICT
  34.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  35.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  36.  * SUCH DAMAGE.
  37.  *
  38.  *    @(#)wdreg.h    7.1 (Berkeley) 5/9/91
  39.  */
  40.  
  41. /*
  42.  * Disk Controller register definitions.
  43.  */
  44. #define    wd_data        0x0        /* data register (R/W - 16 bits) */
  45. #define wd_error    0x1        /* error register (R) */
  46. #define    wd_precomp    wd_error    /* write precompensation (W) */
  47. #define    wd_seccnt    0x2        /* sector count (R/W) */
  48. #define    wd_sector    0x3        /* first sector number (R/W) */
  49. #define    wd_cyl_lo    0x4        /* cylinder address, low byte (R/W) */
  50. #define    wd_cyl_hi    0x5        /* cylinder address, high byte (R/W)*/
  51. #define    wd_sdh        0x6        /* sector size/drive/head (R/W)*/
  52. #define    wd_command    0x7        /* command register (W)     */
  53. #define    wd_status wd_command        /* immediate status (R)     */
  54.  
  55. #define    wd_altsts    0x206     /*alternate fixed disk status(via 1015) (R)*/
  56. #define    wd_ctlr        0x206     /*fixed disk controller control(via 1015) (W)*/
  57. #define    wd_digin    0x207     /* disk controller input(via 1015) (R)*/
  58.  
  59. /*
  60.  * Status Bits.
  61.  */
  62. #define    WDCS_BUSY    0x80        /* Controller busy bit. */
  63. #define    WDCS_READY    0x40        /* Selected drive is ready */
  64. #define    WDCS_WRTFLT    0x20        /* Write fault */
  65. #define    WDCS_SEEKCMPLT    0x10        /* Seek complete */
  66. #define    WDCS_DRQ    0x08        /* Data request bit. */
  67. #define    WDCS_ECCCOR    0x04        /* ECC correction made in data */
  68. #define    WDCS_INDEX    0x02        /* Index pulse from selected drive */
  69. #define    WDCS_ERR    0x01        /* Error detect bit. */
  70.  
  71. #define WDCS_BITS
  72.     "\020\010busy\006rdy\006wrtflt\005seekdone\004drq\003ecc_cor\002index\001err"
  73.  
  74. #define WDERR_BITS    "\020\010badblk\007uncorr\006id_crc\005no_id\003abort\002tr000\001no_dam"
  75.  
  76. /*
  77.  * Commands for Disk Controller.
  78.  */
  79. #define    WDCC_READ    0x20        /* disk read code */
  80. #define    WDCC_WRITE    0x30        /* disk write code */
  81. #define    WDCC_RESTORE    0x10        /* disk restore code -- resets cntlr */
  82. #define    WDCC_FORMAT    0x50        /* disk format code */
  83. #define    WDCC_SETGEOMETRY    0x91    /* disk geometry code */
  84.  
  85. #define    WD_STEP        0        /* winchester- default 35us step */
  86.  
  87. #define    WDSD_IBM    0xa0        /* forced to 512 byte sector, ecc */
  88.  
  89.  
  90.